---@brief
---
--- https://github.com/elixir-lsp/elixir-ls
---
--- `elixir-ls` can be installed by following the instructions [here](https://github.com/elixir-lsp/elixir-ls#building-and-running).
---
--- 1. Download the zip from https://github.com/elixir-lsp/elixir-ls/releases/latest/
--- 2. Unzip it and make it executable.
---    ```bash
---    unzip elixir-ls.zip -d /path/to/elixir-ls
---    # Unix
---    chmod +x /path/to/elixir-ls/language_server.sh
---    ```
---
--- **By default, elixir-ls doesn't have a `cmd` set.** This is because nvim-lspconfig does not make assumptions about
--- your path. You must add the following to your init.vim or init.lua to set `cmd` to the absolute path ($HOME and
--- ~ are not expanded) of your unzipped elixir-ls.
---
--- ```lua
--- vim.lsp.config('elixirls', {
---     -- Unix
---     cmd = { "/path/to/elixir-ls/language_server.sh" };
---     -- Windows
---     cmd = { "/path/to/elixir-ls/language_server.bat" };
---     ...
--- })
--- ```
---
--- 'root_dir' is chosen like this: if two or more directories containing `mix.exs` were found when searching
--- directories upward, the second one (higher up) is chosen, with the assumption that it is the root of an umbrella
--- app. Otherwise the directory containing the single mix.exs that was found is chosen.

---@type vim.lsp.Config
return {
  filetypes = { 'elixir', 'eelixir', 'heex', 'surface' },
  root_dir = function(bufnr, on_dir)
    local fname = vim.api.nvim_buf_get_name(bufnr)
    --- Elixir workspaces may have multiple `mix.exs` files, for an "umbrella" layout or monorepo.
    --- So we specify `limit=2` and treat the highest one (if any) as the root of an umbrella app.
    local matches = vim.fs.find({ 'mix.exs' }, { upward = true, limit = 2, path = fname })
    local child_or_root_path, maybe_umbrella_path = unpack(matches)
    local root_dir = vim.fs.dirname(maybe_umbrella_path or child_or_root_path)

    on_dir(root_dir)
  end,
}
